# INTEGRATED CIRCUITS



Preliminary specification File under Integrated Circuits, IC01 2000 Nov 17



HILIP

### CONTENTS

|                       |                                                                          | 8.4.1                | Re             |
|-----------------------|--------------------------------------------------------------------------|----------------------|----------------|
| 1                     | FEATURES                                                                 | 8.4.2                | Re             |
| 2                     | GENERAL DESCRIPTION                                                      |                      | me             |
| 3                     | QUICK REFERENCE DATA                                                     | 9                    | LIN            |
| 4                     | ORDERING INFORMATION                                                     | 10                   | RE             |
| 5                     | BLOCK DIAGRAM                                                            |                      | CO             |
| 6                     | PIN CONFIGURATION                                                        | 11                   | DC             |
| 7                     | FUNCTIONAL DESCRIPTION                                                   | 12                   | AC             |
| 7.1                   | Overview                                                                 | 13                   | AP             |
| 7.2                   | SBP-2 automation engine                                                  | 14                   | PA             |
| 7.3                   | DMA interface                                                            | 15                   | SO             |
| 7.4<br>7.4.1          | Microcontroller interface<br>Intel 8031 interface support                | 15.1                 | Intr<br>pac    |
| 7.4.2<br>7.4.3<br>7.5 | Hitachi H8 interface<br>NEC V851 interface support<br>Interrupt handling | 15.2<br>15.3<br>15.4 | Re<br>Wa<br>Ma |
| 7.6                   | Address map for the SAA7356HL                                            | 15.5                 | Sui            |
| 8                     | MICROCONTROLLER COMMUNICATION<br>WITH THE SAA7356HL                      |                      | wa             |
| 8.1                   |                                                                          | 16                   | DA             |
| 0.1                   | Communications initiated by the<br>microcontroller                       | 17                   | DE             |
| 8.2<br>8.3            | Communications initiated by the SAA7356HL<br>Interrupt registers         | 18                   | DIS            |

8.4

### SAA7356HL

| 8.4.1 | Register Access                                     |
|-------|-----------------------------------------------------|
| 8.4.2 | Register definitions for the register access method |
| 9     | LIMITING VALUES                                     |
| 10    | RECOMMENDED OPERATING<br>CONDITIONS                 |
| 11    | DC CHARACTERISTICS                                  |
| 12    | AC CHARACTERISTICS                                  |
| 13    | APPLICATION INFORMATION                             |
| 14    | PACKAGE OUTLINE                                     |
| 15    | SOLDERING                                           |
| 15.1  | Introduction to soldering surface mount<br>packages |
| 15.2  | Reflow soldering                                    |
| 15.3  | Wave soldering                                      |
| 15.4  | Manual soldering                                    |
| 15.5  | Suitability of surface mount IC packages for        |
|       | wave and reflow soldering methods                   |
| 16    | DATA SHEET STATUS                                   |
| 17    | DEFINITIONS                                         |
| 18    | DISCLAIMERS                                         |

RAM access for parameter passing

# SAA7356HL

#### **1 FEATURES**

- Institute of Electrical and Electronics Engineers (IEEE) 1394-1995 standard link layer controller
- Compatible with the P1394a standard
- Fully automated Serial Bus Protocol 2 (SBP-2) transaction layer for data storage applications
- Interface to many of the industry standard Direct Memory Access (DMA) protocols
- Interface to any IEEE1394-1995 or P1394a PHY layer interface
- Very low power comma mode
- Small package
- Single 3.3 V supply voltage with 5 V tolerance.

#### 3 QUICK REFERENCE DATA

#### 2 GENERAL DESCRIPTION

The SAA7356HL is an IEEE1394-1995 and P1394a compliant link layer controller featuring an embedded SBP-2 transaction layer for data storage applications. The SAA7356HL provides full automation of the SBP-2 transaction layer to an extent that the user need not have knowledge of SBP-2 or 1394.

| SYMBOL          | PARAMETER      | CONDITIONS              | MIN.   | TYP.   | MAX.   | UNIT |
|-----------------|----------------|-------------------------|--------|--------|--------|------|
| V <sub>DD</sub> | supply voltage |                         | 3.0    | 3.3    | 3.6    | V    |
| I <sub>DD</sub> | supply current | V <sub>DD</sub> = 3.3 V | -      | 29     | -      | mA   |
| SCLK            | system clock   |                         | 49.147 | 49.152 | 49.157 | MHz  |

#### 4 ORDERING INFORMATION

| ТҮРЕ      | PACKAGE |                                                                                    |          |
|-----------|---------|------------------------------------------------------------------------------------|----------|
| NUMBER    | NAME    | DESCRIPTION                                                                        | VERSION  |
| SAA7356HL | LQFP80  | plastic low profile quad flat package; 80 leads; body $12 \times 12 \times 1.4$ mm | SOT315-1 |

# SAA7356HL

#### 5 BLOCK DIAGRAM



# SAA7356HL

#### 6 PIN CONFIGURATION

| SYMBOL              | PIN | TYPE <sup>(1)</sup> | DESCRIPTION                                                                                                                  |
|---------------------|-----|---------------------|------------------------------------------------------------------------------------------------------------------------------|
| MICRO_ADDR[0]       | 1   | 1                   | microcontroller address input (bit 0); note 2                                                                                |
| MICRO_ADDR[1]       | 2   | 1                   | microcontroller address input (bit 1); note 2                                                                                |
| MICRO_ADDR[2]       | 3   | 1                   | microcontroller address input (bit 2); note 2                                                                                |
| MICRO_ADDR[3]       | 4   | 1                   | microcontroller address input (bit 3); note 2                                                                                |
| V <sub>DD1(P)</sub> | 5   | S                   | supply voltage 1 for periphery                                                                                               |
| V <sub>SS1(P)</sub> | 6   | S                   | ground 1 for periphery                                                                                                       |
| MICRO_ADDR[4]       | 7   | 1                   | microcontroller address input (bit 4); note 2                                                                                |
| MICRO_ADDR[5]       | 8   | 1                   | microcontroller address input (bit 5); note 2                                                                                |
| MICRO_ADDR[6]       | 9   | 1                   | microcontroller address input (bit 6); note 2                                                                                |
| MICRO_ADDR[7]       | 10  | I                   | microcontroller address input (bit 7); note 2                                                                                |
| V <sub>DD2(P)</sub> | 11  | S                   | supply voltage 2 for periphery                                                                                               |
| V <sub>SS2(P)</sub> | 12  | S                   | ground 2 for periphery                                                                                                       |
| DMA_DATA[15]        | 13  | I /O                | DMA data input/output (bit 15); note 3                                                                                       |
| DMA_DATA[14]        | 14  | 1/0                 | DMA data input/output (bit 14); note 3                                                                                       |
| DMA_DATA[13]        | 15  | I /O                | DMA data input/output (bit 13); note 3                                                                                       |
| DMA_DATA[12]        | 16  | 1/0                 | DMA data input/output (bit 12); note 3                                                                                       |
| DMA_DATA[11]        | 17  | 1/0                 | DMA data input/output (bit 11); note 3                                                                                       |
| DMA_DATA[10]        | 18  | 1/0                 | DMA data input/output (bit 10); note 3                                                                                       |
| V <sub>DD1(C)</sub> | 19  | S                   | supply voltage 1 for core                                                                                                    |
| V <sub>SS1(C)</sub> | 20  | S                   | ground 1 for core                                                                                                            |
| DMA_DATA[9]         | 21  | I /O                | DMA data input/output (bit 9); note 3                                                                                        |
| DMA_DATA[8]         | 22  | I /O                | DMA data input/output (bit 8); note 3                                                                                        |
| DMA_DATA[7]         | 23  | I /O                | DMA data input/output (bit 7); note 3                                                                                        |
| DMA_DATA[6]         | 24  | I /O                | DMA data input/output (bit 6); note 3                                                                                        |
| DMA_DATA[5]         | 25  | I /O                | DMA data input/output (bit 5); note 3                                                                                        |
| DMA_DATA[4]         | 26  | I /O                | DMA data input/output (bit 4); note 3                                                                                        |
| DMA_DATA[3]         | 27  | I /O                | DMA data input/output (bit 3); note 3                                                                                        |
| DMA_DATA[2]         | 28  | I /O                | DMA data input/output (bit 2); note 3                                                                                        |
| V <sub>SS3(P)</sub> | 29  | S                   | ground 3 for periphery                                                                                                       |
| V <sub>DD3(P)</sub> | 30  | S                   | supply voltage 3 for periphery                                                                                               |
| DMA_DATA[1]         | 31  | I /O                | DMA data input/output (bit 1); note 3                                                                                        |
| DMA_DATA[0]         | 32  | I /O                | DMA data input/output (bit 0); note 3                                                                                        |
| DMA_REQ             | 33  | 0                   | DMA request signal output in slave mode (acknowledge in master/ATA mode) (may be configured for active HIGH or active LOW)   |
| DMA_ACK             | 34  | 1                   | DMA acknowledge signal input in slave mode (request in master/ATA mode)<br>(may be configured for active HIGH or active LOW) |
| V <sub>SS2(C)</sub> | 35  | S                   | ground 2 for core                                                                                                            |
| V <sub>DD2(C)</sub> | 36  | S                   | supply voltage 2 for core                                                                                                    |
| DMA_READ            | 37  | I /O                | DMA read strobe input/output (may be configured for active HIGH or active LOW)                                               |

| SYMBOL              | PIN | TYPE <sup>(1)</sup> | DESCRIPTION                                                                                                                                      |  |  |  |
|---------------------|-----|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| DMA_WRITE           | 38  | I /O                | DMA write strobe input/output (may be configured for active HIGH or active LOW)                                                                  |  |  |  |
| PHY_CTRL[1]         | 39  | 1/0                 | PHY control line input/output (1); note 4                                                                                                        |  |  |  |
| PHY_CTRL[0]         | 40  | 1/0                 | PHY control line input/output (0); note 4                                                                                                        |  |  |  |
| PHY_DATA[0]         | 41  | 1/0                 | PHY data input/output (bit 0); notes 4, 5 and 6                                                                                                  |  |  |  |
| PHY_DATA[1]         | 42  | 1/0                 | PHY data input/output (bit 1); notes 4 and 5                                                                                                     |  |  |  |
| PHY_DATA[2]         | 43  | 1/0                 | PHY data input/output (bit 2); notes 4 and 5                                                                                                     |  |  |  |
| PHY_DATA[3]         | 44  | 1/0                 | PHY data input/output (bit 3); notes 4 and 5                                                                                                     |  |  |  |
| V <sub>SS4(P)</sub> | 45  | S                   | ground 4 for periphery                                                                                                                           |  |  |  |
| V <sub>DD4(P)</sub> | 46  | S                   | supply voltage 4 for periphery                                                                                                                   |  |  |  |
| PHY_DATA[4]         | 47  | 1/0                 | PHY data input/output (bit 4); notes 4 and 5                                                                                                     |  |  |  |
| PHY_DATA[5]         | 48  | 1/0                 | PHY data input/output (bit 5); notes 4 and 5                                                                                                     |  |  |  |
| PHY_DATA[6]         | 49  | 1/0                 | PHY data input/output (bit 6); notes 4 and 5                                                                                                     |  |  |  |
| PHY_DATA[7]         | 50  | 1/0                 | PHY data input/output (bit 7); notes 4 and 5                                                                                                     |  |  |  |
| V <sub>DD5(P)</sub> | 51  | S                   | supply voltage 5 for periphery                                                                                                                   |  |  |  |
| V <sub>SS5(P)</sub> | 52  | s                   | ground 5 for periphery                                                                                                                           |  |  |  |
| PHY_SCLK            | 53  | 1                   | PHY system clock input (49.152 MHz)                                                                                                              |  |  |  |
| MICRO_SEL[0]        | 54  | 1                   | microcontroller select (0) input; selects microcontroller interface; note 10                                                                     |  |  |  |
| PHY_LREQ            | 55  | 0                   | PHY-Link request output (used to request arbitration or read/write PHY registers); note 4                                                        |  |  |  |
| PHY_ISO             | 56  | 1                   | PHY isolation barrier input (active LOW). Negated HIGH when the Link and PHY are directly connected or when bus-holder isolation is used; note 4 |  |  |  |
| MICRO_SEL[1]        | 57  | 1                   | microcontroller select (1) input; selects microcontroller interface; note 10                                                                     |  |  |  |
| 1394_MODE           | 58  | 1/0                 | note 7                                                                                                                                           |  |  |  |
| RESET               | 59  | 1                   | asynchronous master reset input to the SAA7356HL (active LOW)                                                                                    |  |  |  |
| ТС                  | 60  | -                   | reserved for factory testing; for normal operation should be connected to ground                                                                 |  |  |  |
| BT                  | 61  | -                   | reserved for factory testing; for normal operation should be connected to ground                                                                 |  |  |  |
| MICRO_CS            | 62  | 1                   | microcontroller chip select input (active LOW)                                                                                                   |  |  |  |
| V <sub>DD3(C)</sub> | 63  | S                   | supply voltage 3 for core                                                                                                                        |  |  |  |
| V <sub>SS3(C)</sub> | 64  | S                   | ground 3 for core                                                                                                                                |  |  |  |
| MICRO_INT           | 65  | 0                   | microcontroller interrupt open-drain output (active LOW)                                                                                         |  |  |  |
| MICRO_WRITE         | 66  | 1                   | microcontroller write strobe input (active LOW)                                                                                                  |  |  |  |
| MICRO_READ          | 67  | 1                   | microcontroller read strobe input (active LOW)                                                                                                   |  |  |  |
| MICRO_ALE           | 68  | 1                   | microcontroller address latch enable input; note 8                                                                                               |  |  |  |
| V <sub>SS6(P)</sub> | 69  | S                   | ground 6 for periphery                                                                                                                           |  |  |  |
| V <sub>DD6(P)</sub> | 70  | S                   | supply voltage 6 for periphery                                                                                                                   |  |  |  |
| MICRO_DATA[0]       | 71  | 1/0                 | microcontroller data input/output [bit 0); note 9                                                                                                |  |  |  |
| MICRO_DATA[1]       | 72  | 1/0                 | microcontroller data input/output (bit 1); note 9                                                                                                |  |  |  |
| MICRO_DATA[2]       | 73  | 1/0                 | microcontroller data input/output (bit 2); note 9                                                                                                |  |  |  |
| MICRO_DATA[3]       | 74  | 1/0                 | microcontroller data input/output (bit 3); note 9                                                                                                |  |  |  |

### SAA7356HL

| <b></b>             |     | 1                   |                                                   |
|---------------------|-----|---------------------|---------------------------------------------------|
| SYMBOL              | PIN | TYPE <sup>(1)</sup> | DESCRIPTION                                       |
| MICRO_DATA[4]       | 75  | 1/0                 | microcontroller data input/output (bit 4); note 9 |
| MICRO_DATA[5]       | 76  | 1/0                 | microcontroller data input/output (bit 5); note 9 |
| V <sub>SS4(C)</sub> | 77  | S                   | ground 4 for core                                 |
| V <sub>DD4(C)</sub> | 78  | S                   | supply voltage 4 for core                         |
| MICRO_DATA[6]       | 79  | 1/0                 | microcontroller data input/output (bit 6); note 9 |
| MICRO_DATA[7]       | 80  | 1/0                 | microcontroller data input/output (bit 7); note 9 |

#### Notes

- 1. Pin type abbreviations: I = Input, O = Output and S = Supply.
- 2. Used in NEC V851 and 16-bit Intel 8031 microcontroller interface configurations.
- 3. DMA data to the external buffer manager may be configured for 16 or 8 bits wide. For 16-bit operation pins DMA\_DATA[15:0] are used, and for 8-bit operation, pins DMA\_DATA[7:0] are used.
- 4. For more information see IEEE1394-1995 standard, Annex J.
- 5. Data is expected on PHY\_DATA[0:1] for 100 Mbits/s, PHY\_DATA[0:3] for 200 Mbits/s and PHY\_DATA[0:7] for 400 Mbits/s.
- To preserve compatibility to the specified Link-PHY interface of the IEEE1394-1995 standard, Annex J, bit 0 is the most significant bit.
- During Power-on reset, this line is sampled to select between IEEE1394-1995 mode (HIGH) and P1394a mode (LOW). A 22 kΩ pull-up or pull-down resistor should be connected accordingly. This line acts as the MICRO\_WAIT line when the V851 microcontroller interface mode is selected.
- 8. Used in NEC V851 and Intel 8031 (8-bit and 16-bit) microcontroller interface configurations.
- 9. This is the data bus for all microcontroller interface configurations. This forms the lower address bus for the NEC V851 and Intel 8031 microcontroller configurations.
- 10. MICRO\_SEL [1:0] = '00' selects 8-bit 8031 mode; MICRO\_SEL [1:0] = '01' selects H8 mode; MICRO\_SEL [1:0] = '10' selects 16-bit 8031 mode; MICRO\_SEL [1:0] = '11' V851 mode.



SAA7356HL

#### 7 FUNCTIONAL DESCRIPTION

#### 7.1 Overview

The SAA7356HL is an IEEE1394-1995 and P1394a compliant link layer controller. It provides a direct interface between a 1394 bus and a DMA interface found on many buffer managers (see Fig.3). Through this interface, the SBP-2 automation engine performs all transaction layer specific operations; these include the management agent, fetch agent, and page table handling features.

The SBP-2 link also provides an interface to an external microcontroller. The microcontrollers supported include 8/16-bit addressing from the Intel 8031 derivatives, the Hitachi H8 and the NEC V851. Through this interface, the microcontroller retrieves the 12-byte Command Descriptor Blocks (CDBs) and provides the command status indication; unsolicited status information is also supported.



#### 7.2 SBP-2 automation engine

The complete SBP-2 transaction layer is supported by the SAA7356HL. This includes the log-in, log-out and reconnect functions in the management agent plus the fetch engine for retrieving linked lists of Operation Request Blocks (ORBs) from the logged-in node. The data transfers plus the required flow control and target node page-table management are also supported. The transaction layer parses the ORBs to extract the CDBs and presents them to the microcontroller. The microcontroller returns status indication to the transaction layer: the SBP-2 engine then returns this information plus the transaction status information to the logged-in node.

The SAA7356HL will present all Configuration-ROM reads to the microcontroller.

The microcontroller will return the requested information. The SAA7356HL will then add the required header for the 1394 transaction to service these requests.

#### 7.3 DMA interface

The SAA7356HL supports many formats of DMA interface. The DMA bus width may be 8 or 16 bits wide. The polarity of the request, acknowledge, read and write strobes can be configured for active HIGH or active LOW. The DMA controller may also be configured as a master or a slave. In the slave mode, the burst length can also be configured. All configuration details are loaded into the SAA7356HL via a shared page in the Static Random Access Memory (SRAM).

### SAA7356HL

In slave mode a buffer data transfer begins when the DMA interface asserts the DMA\_REQ pin. The buffer manager responds with the DMA\_ACK signal. The burst configuration defines the number of bytes/words to keep DMA\_REQ asserted. The settings include:

- DMA\_REQ is asserted until the last byte/word is transferred or until there is no space/data available in the FIFO
- DMA\_REQ is asserted and negated for each byte/word transferred
- DMA\_REQ is not asserted unless there is space/data available in the FIFO
- the DMA interface waits until there are at least two bytes/words of data/space in the FIFO before asserting DMA\_REQ (in this case, DMA\_REQ remains asserted for the two bus transfers and then de-asserts); and
- the DMA interface waits until there are at least four bytes/words of data/space in the FIFO before asserting DMA\_REQ (in this case, DMA\_REQ remains asserted for the four bus transfers and then de-asserts).

This process repeats until all of the data is transferred. In slave mode, there are three modes of operation for moving data between the SAA7356HL and the DMA interface:

- Mode 0: DMA\_WRITE strobes the data from the buffer memory data bus into the FIFO; DMA\_READ gates the data from the FIFO onto the buffer memory data bus
- Mode 1: DMA\_WRITE strobes the data from the buffer memory into the FIFO. DMA\_ACK gates data from the FIFO onto the buffer memory data bus
- Mode 2: DMA\_ACK strobes the data from the buffer memory bus into the FIFO and also gates the data from the FIFO onto the buffer memory data bus.

In slave mode the DMA interface drives the DMA\_REQ pin and waits for the buffer manager to acknowledge the request via DMA\_ACK as described above. In master mode, the buffer manager drives the DMA\_REQ pin and the DMA interface acknowledges the availability of data/space with the DMA\_ACK pin.

The read or write strobes are driven by the buffer manager in slave mode, and by the DMA interface in master mode. All mode selections listed above are also valid in master mode, however it should be noted that the burst configuration is not applicable in master mode.

Burst size in master mode is determined by the buffer manager request signal, and DMA interface flow control by the time duration between successive acknowledge assertions or read/write assertions. In master mode the SAA7356HL appears to be an Advanced Technology Attachment (ATA) host and can be connected to an ATA or Advanced Technology Attachment Packet Interface (ATAPI) peripheral. The SAA7356HL output signal (DMA\_REQ) behaves like the acknowledge on the Integrated Drive Electronics (IDE) bus; the input signal (DMA\_ACK) behaves like the request line on the IDE bus.

The configuration information is provided via a communication page which is shared between the microcontroller and the SAA7356HL. The connections for the various modes are shown in Figs 4 and 5.

#### 7.4 Microcontroller interface

Because of the high-level protocol support, only ten addresses are required. The user should note that all of the internal SAA7356HL registers are still accessible and so the chip-select line should be used to ensure that the SAA7356HL is not accessed accidentally. The behaviour on accessing these other addresses is not specified.

When used in V851 and H8 modes, the  $\overline{\text{MICRO}_{WAIT}}$  line is asserted within 4 ns of the  $\overline{\text{MICRO}_{READ}}$  falling edge.

For all modes of operation, the data bus is the MICRO\_DATA bus. The microcontroller interface can be configured for four modes of operation, namely:

- Mode 0: 8-bit addressed Intel 8031 peripheral (multiplexed address/data bus)
- Mode 1: 8-bit addressed Hitachi H8 peripheral (non-multiplexed address and data buses)
- Mode 2: 16-bit addressed Intel 8031 peripheral (lower address from multiplexed address/data bus)
- Mode 3: 16-bit addressed NEC V851 peripheral (acting as an 8-bit peripheral).

#### 7.4.1 INTEL 8031 INTERFACE SUPPORT

The microcontroller interface logic supports the industry standard 8031 style interface.

On reading, the MICRO\_DATA output is enabled as soon as the MICRO\_READ is asserted. Before this happens, the address will have already been decoded and the internal Data Out signal asserted. On writing, the data is loaded from the rising edge of MICRO\_WRITE.



### SAA7356HL

#### 7.4.2 HITACHI H8 INTERFACE

In this mode, the address and data buses are non-multiplexed. The address bus is connected directly to the MICRO\_ADDR pins and the data bus is connected directly onto the MICRO\_DATA pins.

The MICRO\_CS pin must be asserted before the assertion of the MICRO\_READ pin. The SAA7356HL will stop driving the microcontroller data bus when either the MICRO\_CS pin or the MICRO\_READ pin are negated.

The H8 microcontroller supports wait states. The timing is shown in Fig.6. Note that the MICRO\_WAIT pin must be low during the falling edge of the (H8) CLK during state T2. Since the relationship between the SAA7356HL and the H8 clock is unknown the MICRO\_WAIT pin is asserted low when the MICRO\_READ and the MICRO\_CS are asserted. The SAA7356HL will de-assert the MICRO\_WAIT line once the data is ready for transfer.

7.4.3 NEC V851 INTERFACE SUPPORT

The most important timing information for this microcontroller is given in Fig.7.

The  $\overline{\text{MICRO}_WAIT}$  line must be low during the falling edge of the (V851) CLK during state T2: this is the same requirement as the H8. Instead of a  $\overline{\text{MICRO}_READ}$  and a  $\overline{\text{MICRO}_WRITE}$  signal the V851 uses a R/W and DSTB signal. The address lines are time multiplexed and should be latched using the ASTB signal.

#### 7.5 Interrupt handling

The SAA7356HL may use interrupts to communicate with the microcontroller. The microcontroller will read from the **CmdToMicro** register to find the interrupt reason. If parameters are required with the command then this is implied in the command byte. These parameters may then be read from the SAA7356HL RAM using the **RAM.Offset** and the **RAM.Next** registers.

#### 7.6 Address map for the SAA7356HL

The address mapping for the 4-bit, 8-bit and 16-bit addressing modes is given in Table 1.

|        | ADDRES       | S                     | MNEMONIC        | COMMENT                                                                       |  |  |  |  |
|--------|--------------|-----------------------|-----------------|-------------------------------------------------------------------------------|--|--|--|--|
| 4-BIT  | 8-BIT        | 16-BIT                |                 |                                                                               |  |  |  |  |
| 0      | 9C           | FF90                  | Reserved        | reserved                                                                      |  |  |  |  |
| 1      | 9D           | FF91                  | InterruptEnable | enables the InterruptReason to assert the<br>microcontroller interrupt line   |  |  |  |  |
| 2      | 9E           | FF92                  | InterruptReason | provides the interrupt sources                                                |  |  |  |  |
| 3      | 9F           | FF93                  | CmdFromMicro    | command byte channel from the microcontroller to the SAA7356HL                |  |  |  |  |
| 4      | BC           | FFB0                  | CmdToMicro      | command byte from the SAA7356HL to the microcontroller                        |  |  |  |  |
| 5      | BD           | FFB1                  | Sbp2Start       | used to complete the SAA7356HL initialization sequence                        |  |  |  |  |
| 6      | BE           | FFB2                  | InterruptSet    | allows setting of the flags in the InterruptReason register                   |  |  |  |  |
| 7 to B | BF, DC to DF | FFB3,<br>FFD0 to FFD3 | Reserved        | reserved                                                                      |  |  |  |  |
| С      | FC           | FFF0                  | RAM.OffsetB     | High-byte of the offset address                                               |  |  |  |  |
| D      | FD           | FFF1                  | RAM.OffsetA     | Low-byte for the offset address                                               |  |  |  |  |
| E      | FE           | FFF2                  | RAM.Next        | RAM access register: forces a post-increment of the <b>RAM.Offset</b> address |  |  |  |  |
| F      | FF           | FFF3                  | RAM.Current     | RAM access register: no modification to the <b>RAM.Offset</b> address         |  |  |  |  |

#### Table 1 Big-endian register map for the SAA7356HL





### SAA7356HL

#### 8 MICROCONTROLLER COMMUNICATION WITH THE SAA7356HL

The communications protocol from a hardware perspective is described in the following sections.

The automation engine within the SAA7356HL performs all of the functions necessary to support the SBP-2 protocol layer. The microcontroller and the SAA7356HL communicate via command registers and access to the shared RAM resource.

The microcontroller will download the configuration information into the SAA7356HL after a Power-on reset. Once this has been done, the power-on sequence will be completed when the microcontroller writes any value to the **Sbp2Start** register. To download the configuration information, the microcontroller simply copies a binary image (provided by Philips Semiconductors) and writes repetitively into the **RAM.Next** address.

# 8.1 Communications initiated by the microcontroller

The microcontroller may send a message to the SAA7356HL by writing to the CmdFromMicro register. Once the SAA7356HL has used this register, the SAA7356HL will assert the maskable interrupt, InterruptReason.CmdClr, to the microcontroller. The value in the CmdFromMicro register will remain. On receiving the InterruptReason.CmdClr interrupt, the microcontroller will read from the InterruptReason register to determine the source of this interrupt. To clear the interrupt, the microcontroller must write a logic 1 to the InterruptReason.CmdClr bit: writing a logic 0 to this location has no effect. An alternative control protocol may be used. As the SAA7356HL acknowledges the CmdFromMicro, the InterruptReason.CmdClr is asserted as before. The user may decide to mask this interrupt and use a polling technique.

On detecting completion of the previous command via InterruptReason.CmdClr, the microcontroller may write another command into the CmdFromMicro register: this will clear the InterruptReason.CmdClr flag and so there is no need for the microcontroller to perform another operation to explicitly clear this flag. This style of communication is used to realize a simple command-driven communication protocol in which the microcontroller sends command bytes to the SAA7356HL. If no parameters are required, there is no need to write to a shared memory location and hence there is no need to write to the RAM Access **Offset**, **Current** and **Next** registers. The **CmdFromMicro** register definition is given in Table 2.

In addition to the **CmdFromMicro** register, the microcontroller can also write to the **Sbp2Start** register. This is used in the system initialization sequence. The value that is written has no significance and reading from this address will return zeros.

When using this command to initialize the SAA7356HL, the microcontroller may first write to a pre-designated memory area for the parameter passing and then write to the **Sbp2Start** register to start the requested action. The **Sbp2Start** register definition is given in Table 3.

#### 8.2 Communications initiated by the SAA7356HL

The SAA7356HL has only one form of communication to the microcontroller: the SAA7356HL will write to the **CmdToMicro** register. On writing to this register, the maskable **CmdMicro** bit in the **InterruptReason** register is asserted, which in turn may assert the maskable interrupt to the microcontroller. The microcontroller will read from the **InterruptReason** register to determine the cause of the interrupt. If no data is required from the communication then the microcontroller can determine this from the value in the **CmdToMicro** register. The **CmdToMicro** register definition is given in Table 4.

If data or parameters are needed then the SAA7356HL will first write to the RAM and then write to the **CmdToMicro** register. To signal acknowledgment of the interrupt, the microcontroller writes a logic 1 to the **CmdMicro** bit in the **InterruptReason** register which also has the effect of clearing the **CmdMicro** bit and negating the interrupt (if no other interrupts are pending): writing a logic 0 to the **CmdMicro** bit has no effect. On signalling the acknowledgment, the value in the **CmdToMicro** register is unchanged, but now the SAA7356HL is free to modify the **CmdToMicro** register contents.

### SAA7356HL

| BYTE<br>NUMBER | BIT 7        | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|----------------|--------------|-------|-------|-------|-------|-------|-------|-------|
| 0              | Command(7:0) |       |       |       |       |       |       |       |

#### Table 2 CmdFromMicro register definition (read/write)

#### Table 3 Sbp2Start register definition (read/write)

| BYTE<br>NUMBER | BIT 7     | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|----------------|-----------|-------|-------|-------|-------|-------|-------|-------|
| 0              | Command(7 | (:0)  |       |       |       |       |       |       |

 Table 4
 CmdToMicro register definition (read/write)

| BYTE<br>NUMBER | BIT 7        | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|----------------|--------------|-------|-------|-------|-------|-------|-------|-------|
| 0              | Command(7:0) |       |       |       |       |       |       |       |

#### 8.3 Interrupt registers

As mentioned in the previous section, the communications may be interrupt driven. To facilitate this there is one **InterruptReason** and one **InterruptEnable** register. The interrupt to the microcontroller is of the AND-OR type and is asserted when any of the maskable interrupts are enabled and active: to enable an interrupt, the corresponding field in the **InterruptEnable** register must be set to logic 1. Reading from the **InterruptReason** register provides the un-masked value: this allows polling if desired.

The **InterruptEnable** and **InterruptReason** register definitions are shown in Tables 5 and 6 respectively.

In addition to these two registers, the microcontroller may set the values in the **InterruptReason** register: this may be used for setting initial conditions, for example. To set the required bits, a logic 1 must be written to the flag location in the **InterruptSet** register: writing a logic 0 to any bit-field has no effect. The **InterruptSet** register definition is given in Table 7.

It is recommended that only the InterruptReason.CmdClr flag is set as InterruptReason.CmdMicro will cause a maskable interrupt to be asserted to the microcontroller.

The definition of the InterruptReason, InterruptEnable and the InterruptSet register fields are shown in Table 8.

| Table 5 | InterruptEnable register definition (re | ead/write) |
|---------|-----------------------------------------|------------|
|---------|-----------------------------------------|------------|

| BYTE<br>NUMBER | BIT 7    | BIT 6 BIT 5 |  | BIT 4 | BIT 3 | BIT 2    | BIT 1    | BIT 0  |
|----------------|----------|-------------|--|-------|-------|----------|----------|--------|
| 0              | Reserved |             |  |       |       | CmdMicro | BusReset | CmdClr |

 Table 6
 InterruptReason register definition (read/write)

| BYTE<br>NUMBER | BIT 7    | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2    | BIT 1    | BIT 0  |
|----------------|----------|-------|-------|-------|-------|----------|----------|--------|
| 0              | Reserved |       |       |       |       | CmdMicro | BusReset | CmdClr |

 Table 7
 InterruptSet register definition (write only, read via InteruptReason)

| BYTE<br>NUMBER | BIT 7    | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2    | BIT 1    | BIT 0  |
|----------------|----------|-------|-------|-------|-------|----------|----------|--------|
| 0              | Reserved |       |       |       |       | CmdMicro | Reserved | CmdClr |

### SAA7356HL

| MNEMONIC | VALUE | COMMENT                                                                      |
|----------|-------|------------------------------------------------------------------------------|
| CmdClr   | 0     | default condition: no action occurred                                        |
|          | 1     | the SAA7356HL device has acknowledged the write to the CmdFromMicro register |
| BusReset | 0     | default condition: no action occurred                                        |
|          | 1     | the SAA7356HL has detected a serial bus reset                                |
| CmdMicro | 0     | default condition: no action occurred                                        |
|          | 1     | the SAA7356HL has written a command into the CmdToMicro register             |
| Reserved | Х     | reserved and set to zero                                                     |

 Table 8
 Definition of the InterruptReason, InterruptEnable and InterruptSet register fields

#### 8.4 RAM access for parameter passing

Within the SAA7356HL there is a 16 kbyte RAM. This is shared between: the IEEE1394 transaction FIFOs, the code for the automation engine and its local storage requirements, and the shared memory area for communications with the microcontroller.

The SAA7356HL user must understand how this shared memory is accessed in order to write and read the communications parameters. Each of the read and write accesses to the FIFOs are byte-wide and the offset addresses are byte offsets.

#### 8.4.1 REGISTER ACCESS

The RAM can be directly accessed to upload the code into the SAA7356HL. The C-structure for the registers for the RAM access is shown below.

#### struct RAM {

U16; offset; // absolute offset into the RAM U8; next; // read/write data at offset and post-increment U8; current; // read/write data at offset };

The **RAM.Offset** field allows the microcontroller to access anywhere within the SAA7356HL RAM. The **RAM.Next** accesses will access the **RAM.Offset** address and post-increment the offset pointer. Accesses to the **RAM.Current** address allow reads and writes to the data in the **RAM.Offset** location without altering the **RAM.Offset** address.

The ability to write to anywhere within the RAM is used for the power-on sequence.

8.4.2 REGISTER DEFINITIONS FOR THE REGISTER ACCESS METHOD

This section defines the register structure for the **RAM** registers.

The **RAM.Offset** registers are used to index into the RAM inside the SAA7356HL. The index is a byte address. The **RAM.Offset** register definition is shown in Table 9.

The **RAM.Next** register is used to read or write to the RAM location addressed by the **RAM.Offset** register. Once an access has been made, the value of the **RAM.Offset** register is incremented to simplify the process of reading or writing contiguous memory areas. The **RAM.Next** register definition is shown in Table 10.

The **RAM.Current** register is used to read or write to the RAM location addressed by the **RAM.Offset** register. Once an access has been made there is no change to the **RAM.Offset** register. The **RAM.Current** register definition is shown in Table 11.

## SAA7356HL

Table 9 Definition of the RAM.Offset registers (read/write)

| BYTE<br>NUMBER | BIT 7       | BIT6            | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |  |  |  |
|----------------|-------------|-----------------|-------|-------|-------|-------|-------|-------|--|--|--|
| 0              | RAM.Offset( | RAM.Offset(7:0) |       |       |       |       |       |       |  |  |  |
| 1              | Reserved    |                 |       |       |       |       |       |       |  |  |  |

#### Table 10 Definition of the RAM.Next register (read/write)

| BYTE<br>NUMBER | BIT 7      | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|----------------|------------|-------|-------|-------|-------|-------|-------|-------|
| 0              | RAM.Next(7 | :0)   |       |       |       |       |       |       |

#### Table 11 Definition of the RAM.Current register (read/write)

| BYTE<br>UMBER | BIT 7      | BIT 6            | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|---------------|------------|------------------|-------|-------|-------|-------|-------|-------|
| 0             | RAM.Curren | RAM.Current(7:0) |       |       |       |       |       |       |

### SAA7356HL

#### 9 LIMITING VALUES

In accordance with the Absolute Maximum Rating System (IEC 60134); voltages are referenced to ground (ground = 0 V); notes 1 and 2.

| SYMBOL                            | PARAMETER                      | CONDITIONS                   | MIN. | MAX.                  | UNIT |
|-----------------------------------|--------------------------------|------------------------------|------|-----------------------|------|
| V <sub>DD</sub>                   | supply voltage                 |                              | -0.5 | +4.0                  | V    |
| I <sub>IK</sub>                   | input clamping diode current   |                              | -    | -50                   | mA   |
| VI                                | input voltage                  | microcontroller and DMA pins | -0.5 | +5.5                  | V    |
|                                   |                                | PHY pins                     | -    | V <sub>DD</sub> + 0.5 | V    |
| I <sub>OK</sub>                   | output clamping diode current  |                              | -    | ±50                   | mA   |
| Vo                                | output voltage                 |                              | -0.5 | V <sub>DD</sub> + 0.5 | V    |
| I <sub>O(source)</sub>            | output source current          |                              | -    | ±150                  | mA   |
| I <sub>O(sink)</sub>              | output sink current            |                              | -    | ±150                  | mA   |
| I <sub>SS</sub> – I <sub>CC</sub> | V <sub>CC</sub> or GND current |                              | -    | ±150                  | mA   |
| T <sub>stg</sub>                  | storage temperature            |                              | -60  | +150                  | °C   |
| T <sub>amb</sub>                  | ambient temperature            |                              | 0    | 70                    | °C   |
| P <sub>tot</sub>                  | total power dissipation        | package                      | -    | 380                   | mW   |
|                                   |                                | comma mode                   | -    | 82                    | μW   |

#### Notes

- 1. Stresses beyond those listed may cause permanent damage to the device. These are stress ratings only and functional operation of the device at these or any other conditions beyond those indicated in "Recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.
- 2. The performance capability of a high performance integrated circuit in conjunction with its thermal environment can create junction temperatures which are detrimental to reliability. The maximum junction temperature of this integrated circuit should not exceed 150 °C.

#### 10 RECOMMENDED OPERATING CONDITIONS

| SYMBOL                        | PARAMETER                  | CONDITIONS                   | MIN.   | MAX.   | UNIT |
|-------------------------------|----------------------------|------------------------------|--------|--------|------|
| V <sub>DD</sub>               | supply voltage             |                              | 3.0    | 3.6    | V    |
| VI                            | input voltage              | microcontroller and DMA pins | 0      | 5.5    | V    |
|                               |                            | PHY pins                     | 0      | 3.6    | V    |
| VIH                           | HIGH-level input voltage   |                              | 2.0    | _      | V    |
| V <sub>IL</sub>               | LOW-level input voltage    |                              | -      | 0.8    | V    |
| I <sub>OH</sub>               | HIGH-level output current  |                              | -      | 4      | mA   |
| I <sub>OL</sub>               | LOW-level output current   |                              | -      | -4     | mA   |
| $\Delta t_{t(i)(r)}/\Delta V$ | input transition rise time |                              | 0      | 20     | ns/V |
| $\Delta t_{t(i)f)}/\Delta V$  | input transition fall time |                              | 0      | 20     | ns/V |
| T <sub>amb</sub>              | ambient temperature        |                              | 0      | 70     | °C   |
| SCLK                          | system clock               |                              | 49.147 | 49.157 | MHz  |
| t <sub>i(r)</sub>             | input rise time            |                              | -      | 10     | ns   |
| t <sub>i(f)</sub>             | input fall time            |                              | -      | 10     | ns   |

### SAA7356HL

#### 11 DC CHARACTERISTICS

| SYMBOL                | PARAMETER                             | CONDITIONS                         | MIN.                      | TYP. | MAX.                      | UNIT |
|-----------------------|---------------------------------------|------------------------------------|---------------------------|------|---------------------------|------|
| V <sub>IH</sub>       | HIGH-level input voltage              | note 1                             | 2.4                       | _    | _                         | V    |
| V <sub>IL</sub>       | LOW-level input voltage               | note 1                             | -                         | _    | 0.8                       | V    |
| V <sub>I(th)(r)</sub> | input voltage threshold, rising edge  | note 2                             | 0.5V <sub>DD</sub> + 0.12 | _    | 0.5V <sub>DD</sub> + 0.66 | V    |
| V <sub>I(th)(f)</sub> | input voltage threshold, falling edge | note 2                             | 0.5V <sub>DD</sub> - 0.66 | _    | 0.5V <sub>DD</sub> – 0.12 | V    |
| V <sub>OH1</sub>      | HIGH-level output voltage 1           | note 1                             | 2.4                       | _    | _                         | V    |
| V <sub>OL1</sub>      | LOW-level output voltage 1            | note 1                             | -                         | _    | 0.4                       | V    |
| V <sub>OH2</sub>      | HIGH-level output voltage 2           | note 3                             | 2.9                       | _    | _                         | V    |
| V <sub>OL2</sub>      | LOW-level output voltage 2            | note 3                             | -                         | _    | 0.4                       | V    |
| IIL                   | input leakage current                 | note 1                             | -                         | _    | ±1                        | μA   |
|                       |                                       | note 4                             | -                         | _    | 100                       | μA   |
| I <sub>OZ</sub>       | 3-state output current                | note 5                             | -                         | _    | ±5                        | μA   |
|                       |                                       | note 3                             | -                         | _    | 200                       | μA   |
| I <sub>DD</sub>       | active supply current                 | V <sub>DD</sub> = 3.3 V;<br>note 6 | -                         | -    | _                         | mA   |

#### Notes

- 1. Microcontroller and DMA interface pins.
- 2. PHY-Link data and control and PHY\_SCLK pins.
- 3. PHY-Link data and control pins.
- 4. PHY\_SCLK pin.
- 5. Microcontroller, DMA and PHY\_LREQ pins.
- 6. Under idle conditions the average value is 108 mA.

# SAA7356HL

#### 12 AC CHARACTERISTICS

| SYMBOL          | PARAMETER                                                   | CONDITIONS | MIN. | TYP. | MAX. |    |
|-----------------|-------------------------------------------------------------|------------|------|------|------|----|
| DMA INTERI      | FACE WRITE/READ TIMING FOR SLAVE MODE 0; see Fig.8          |            |      |      |      |    |
| t <sub>0</sub>  | cycle time                                                  |            | 67   | _    | _    | ns |
| t <sub>1</sub>  | DMA_REQ de-assert from DMA_ACK assert<br>(single word DMA)  |            | -    | -    | 25   | ns |
| t <sub>2</sub>  | DMA_REQ de-assert from DMA_WRITE assert (multi-word DMA)    |            | -    | -    | 25   | ns |
| t <sub>3</sub>  | DMA_REQ de-assert from DMA_READ assert<br>(multi-word DMA)  |            | -    | -    | 25   | ns |
| t <sub>4</sub>  | DMA_REQ assert after DMA_ACK de-assert                      |            | 8    | -    | -    | ns |
| t <sub>5</sub>  | write data set-up                                           |            | 15   | -    | _    | ns |
| t <sub>6</sub>  | write data hold                                             |            | 5    | -    | -    | ns |
| t <sub>7</sub>  | DMA_WRITE active pulse duration                             |            | 25   | -    | _    | ns |
| t <sub>8</sub>  | read data stable after DMA_READ active                      |            | _    | -    | 10   | ns |
| t <sub>9</sub>  | read data 3-state after DMA_READ inactive                   |            | 5    | -    | 10   | ns |
| t <sub>10</sub> | DMA_REQ assert after DMA_READ and DMA_WRITE negated         |            | 68   | -    | -    | ns |
| DMA INTERI      | FACE WRITE/READ TIMING FOR SLAVE MODE 1; see Fig.9          | •          | •    | •    | ·    |    |
| to              | cycle time                                                  |            | 67   | -    | _    | ns |
| t <sub>1</sub>  | DMA_REQ de-assert from DMA_ACK assert (single word DMA)     |            | -    | -    | 25   | ns |
| t <sub>2</sub>  | DMA_REQ de-assert from DMA_WRITE assert<br>(multi-word DMA) |            | -    | -    | 25   | ns |
| t <sub>3</sub>  | DMA_REQ assert after DMA_ACK de-assert                      |            | 5    | -    | -    | ns |
| t <sub>4</sub>  | read data stable after DMA_ACK assert                       |            | -    | -    | 10   | ns |
| t <sub>5</sub>  | read data 3-state after DMA_ACK inactive                    |            | 5    | -    | 10   | ns |
| t <sub>6</sub>  | write data set-up                                           |            | 15   | -    | _    | ns |
| t <sub>7</sub>  | write data hold                                             |            | 5    | -    | -    | ns |
| t <sub>8</sub>  | DMA_WRITE active pulse width                                |            | 25   | -    | _    | ns |
| DMA INTER       | FACE WRITE/READ TIMING FOR SLAVE MODE 2; see Fig.10         | )          | •    | •    | •    |    |
| t <sub>0</sub>  | cycle time                                                  |            | 67   | _    | _    | ns |
| t <sub>1</sub>  | DMA_REQ de-assert from DMA_ACK assert (single word DMA)     |            | -    | -    | 25   | ns |
| t <sub>2</sub>  | DMA_REQ assert after DMA_ACK de-assert                      |            | 5    | -    | -    | ns |
| t <sub>3</sub>  | write data set-up                                           |            | 15   | -    | -    | ns |
| t <sub>4</sub>  | write data hold                                             |            | 5    | -    | -    | ns |
| t <sub>5</sub>  | DMA_ACK active pulse duration during data write             |            | 25   | -    | -    | ns |
| t <sub>6</sub>  | read data stable after DMA_ACK assert                       |            | -    | -    | 10   | ns |
| t <sub>7</sub>  | read data 3-state after DMA_ACK de-assert                   |            | 5    | -    | 10   | ns |

| SYMBOL          | PARAMETER                                                   | CONDITIONS | MIN. | TYP. | MAX. | UNIT |
|-----------------|-------------------------------------------------------------|------------|------|------|------|------|
| DMA INTER       | FACE WRITE/READ TIMING FOR MASTER MODE 0; note 1;           | see Fig.11 |      |      |      |      |
| t <sub>0</sub>  | cycle time                                                  |            | 40   | -    | -    | ns   |
| t <sub>1</sub>  | DMA_REQ de-assert from DMA_ACK assert (single word DMA)     |            | -    | -    | 30   | ns   |
| t <sub>2</sub>  | DMA_REQ de-assert from DMA_WRITE assert<br>(multi-word DMA) |            | -    | -    | 30   | ns   |
| t <sub>3</sub>  | DMA_REQ de-assert from DMA_READ assert<br>(multi-word DMA)  |            | -    | -    | 30   | ns   |
| t <sub>4</sub>  | DMA_REQ assert after DMA_ACK de-assert                      |            | 0    | _    | -    | ns   |
| t <sub>5</sub>  | write data set-up                                           |            | 20   | _    | -    | ns   |
| t <sub>6</sub>  | write data hold                                             |            | 0    | _    | -    | ns   |
| t <sub>7</sub>  | DMA_WRITE active pulse duration                             |            | 20   | _    | -    | ns   |
| t <sub>8</sub>  | read data stable after DMA_READ active                      |            | _    | _    | 15   | ns   |
| t <sub>9</sub>  | read data 3-state after DMA_READ inactive                   |            | 25   | _    | 30   | ns   |
| t <sub>10</sub> | DMA_WRITE active pulse duration                             |            | 20   | _    | -    | ns   |
| DMA INTER       | FACE WRITE/READ TIMING FOR MASTER MODE 1; note 1;           | see Fig.12 | •    |      |      |      |
| t <sub>0</sub>  | cycle time                                                  |            | 40   | -    | -    | ns   |
| t <sub>1</sub>  | DMA_REQ de-assert from DMA_ACK assert (single word DMA)     |            | -    | -    | 30   | ns   |
| t <sub>2</sub>  | DMA_REQ de-assert from DMA_WRITE assert<br>(multi-word DMA) |            | -    | -    | 30   | ns   |
| t <sub>3</sub>  | DMA_REQ assert after DMA_ACK de-assert                      |            | 0    | -    | -    | ns   |
| t <sub>4</sub>  | read data stable after DMA_ACK assert                       |            | _    | _    | 15   | ns   |
| t <sub>5</sub>  | read data 3-state after DMA_ACK inactive                    |            | 25   | -    | 30   | ns   |
| t <sub>6</sub>  | write data set-up                                           |            | 20   | -    | -    | ns   |
| t <sub>7</sub>  | write data hold                                             |            | 0    | -    | -    | ns   |
| t <sub>8</sub>  | DMA_WRITE active pulse width                                |            | 20   | _    | -    | ns   |
| t <sub>9</sub>  | DMA_ACK active pulse width                                  |            | 20   | _    | -    | ns   |
| DMA INTER       | FACE WRITE/READ TIMING FOR MASTER MODE 2; note 1;           | see Fig.13 |      |      |      | •    |
| t <sub>0</sub>  | cycle time                                                  |            | 40   | -    | -    | ns   |
| t <sub>1</sub>  | DMA_REQ de-assert from DMA_ACK assert (single word DMA)     |            | -    | -    | 30   | ns   |
| t <sub>2</sub>  | DMA_REQ assert after DMA_ACK de-assert                      |            | 0    | -    | -    | ns   |
| t <sub>3</sub>  | write data set-up                                           |            | 20   | -    | -    | ns   |
| t <sub>4</sub>  | write data hold                                             |            | 0    | -    | -    | ns   |
| t <sub>5</sub>  | DMA_ACK active pulse duration during data write             |            | 20   | -    | -    | ns   |
| t <sub>6</sub>  | read data stable after DMA_ACK assert                       |            | -    | -    | 15   | ns   |
| t <sub>7</sub>  | read data 3-state after DMA_ACK de-assert                   |            | 25   | -    | 30   | ns   |

### SAA7356HL

| SYMBOL          | PARAMETER                                           | CONDITIONS | MIN.                | TYP. | MAX. | UNIT |
|-----------------|-----------------------------------------------------|------------|---------------------|------|------|------|
| PHY-LINK IN     | TERFACE TIMING; see Figs 14 and 15                  |            |                     | 1    | 1    | 4    |
| t <sub>1</sub>  | PHY-Link set-up time                                |            | 6                   | _    | -    | ns   |
| t <sub>2</sub>  | PHY-Link hold time                                  |            | 0                   | _    | -    | ns   |
| t <sub>3</sub>  | PHY-Link output delay                               |            | 2                   | -    | 10   | ns   |
| REGISTER IN     | TERFACE TIMING; see Figs 16, 17, 18, 19, 20, 21 and | 22         | •                   |      |      |      |
| t <sub>1</sub>  | address set-up to MICRO_ALE LOW                     |            | 10                  | -    | -    | ns   |
| t <sub>2</sub>  | address hold from MICRO_ALE LOW                     |            | 10                  | -    | -    | ns   |
| t <sub>3</sub>  | MICRO_ALE pulse width note 2                        |            | 20                  | _    | -    | ns   |
| t <sub>4</sub>  | MICRO_ALE LOW to MICRO_CS LOW                       |            | 10                  | -    | -    | ns   |
| t <sub>5</sub>  | MICRO_CS LOW to data valid                          | note 3     | -                   | _    | 280  | ns   |
| t <sub>6</sub>  | MICRO_CS HIGH to MICRO_ALE HIGH                     |            | 0                   | _    | -    | ns   |
| t <sub>7</sub>  | MICRO_CS set-up to MICRO_READ LOW                   | note 4     | 0                   | _    | -    | ns   |
| t <sub>8</sub>  | MICRO_READ pulse width                              | note 5     | 280                 | _    | -    | ns   |
| t <sub>9</sub>  | MICRO_READ HIGH to MICRO_CS HIGH                    | note 4     | 0                   | _    | -    | ns   |
| t <sub>10</sub> | MICRO_READ LOW to data valid                        | note 6     | -                   | _    | 280  | ns   |
| t <sub>11</sub> | MICRO_READ HIGH to data bus disable                 |            | 2                   | _    | 30   | ns   |
| t <sub>12</sub> | MICRO_CS set-up to MICRO_WRITE LOW                  | note 7     | 0                   | -    | -    | ns   |
| t <sub>13</sub> | MICRO_WRITE pulse width                             |            | 30                  | _    | -    | ns   |
| t <sub>14</sub> | MICRO_WRITE HIGH to MICRO_CS HIGH                   | note 7     | 0                   | -    | -    | ns   |
| t <sub>15</sub> | data set-up to MICRO_WRITE HIGH                     |            | 15                  | -    | -    | ns   |
| t <sub>16</sub> | data hold from MICRO_WRITE HIGH                     |            | 4                   | -    | -    | ns   |
| t <sub>17</sub> | MICRO_WRITE HIGH to MICRO_ALE HIGH                  | note 8     | t <sub>CP</sub> + 5 | -    | -    | ns   |
| t <sub>18</sub> | MICRO_WRITE HIGH to MICRO_WRITE HIGH                | note 9     | 280                 | -    | -    | ns   |
|                 |                                                     | note 10    | 460                 | -    | -    | ns   |
| t <sub>19</sub> | MICRO_READ LOW to MICRO_WAIT LOW                    |            | _                   | -    | 4    | ns   |
| t <sub>20</sub> | data valid to MICRO_WAIT HIGH                       |            | -                   | _    | 20   | ns   |

#### Notes

- 1. ATA Multi-word Direct Memory Access (MDMA) protocol with all timing based on an internal DMA interface 50 MHz system clock.
- 2. MICRO\_ALE must pulse to capture a new register address for the Intel 8031 and the NEC V851 modes.
- 3. t<sub>10</sub> must also be satisfied.
- 4. If  $\overline{\text{MICRO}_\text{READ}}$  is held LOW, the time from  $\overline{\text{MICRO}_\text{CS}}$  LOW to stable data is t<sub>5</sub> and the data release time from  $\overline{\text{MICRO}_\text{CS}}$  HIGH is t<sub>11</sub>.
- 5. This is larger than the typical read strobe timing. To meet these requirements, either the microcontroller clock will be stopped by the buffer manager device, or the microcontroller must insert its own wait states.
- 6.  $t_5$  must also be satisfied.
- 7. If MICRO\_WRITE is held LOW, data set-up to MICRO\_CS HIGH is t<sub>15</sub> and data hold from MICRO\_CS is t<sub>16</sub>.
- 8.  $t_3$  minimum = 2 × 3 $t_{CP}$  + 5 for successive FIFO reads or a FIFO read or write followed by a read of the FIFO flag registers.
- 9. This time relates to accesses to addresses other than RAM.Next and RAM.Current.
- 10. This time relates to accesses to the addresses **RAM.Next** and **RAM.Current**.

2000 Nov 17



























### SAA7356HL



#### **13 APPLICATION INFORMATION**



#### 14 PACKAGE OUTLINE

LQFP80: plastic low profile quad flat package; 80 leads; body 12 x 12 x 1.4 mm



# SAA7356HL

SOT315-1

# SAA7356HL

#### 15 SOLDERING

# 15.1 Introduction to soldering surface mount packages

This text gives a very brief insight to a complex technology. A more in-depth account of soldering ICs can be found in our *"Data Handbook IC26; Integrated Circuit Packages"* (document order number 9398 652 90011).

There is no soldering method that is ideal for all surface mount IC packages. Wave soldering can still be used for certain surface mount ICs, but it is not suitable for fine pitch SMDs. In these situations reflow soldering is recommended.

#### 15.2 Reflow soldering

Reflow soldering requires solder paste (a suspension of fine solder particles, flux and binding agent) to be applied to the printed-circuit board by screen printing, stencilling or pressure-syringe dispensing before package placement.

Several methods exist for reflowing; for example, convection or convection/infrared heating in a conveyor type oven. Throughput times (preheating, soldering and cooling) vary between 100 and 200 seconds depending on heating method.

Typical reflow peak temperatures range from 215 to 250 °C. The top-surface temperature of the packages should preferable be kept below 220 °C for thick/large packages, and below 235 °C for small/thin packages.

#### 15.3 Wave soldering

Conventional single wave soldering is not recommended for surface mount devices (SMDs) or printed-circuit boards with a high component density, as solder bridging and non-wetting can present major problems.

To overcome these problems the double-wave soldering method was specifically developed.

If wave soldering is used the following conditions must be observed for optimal results:

- Use a double-wave soldering method comprising a turbulent wave with high upward pressure followed by a smooth laminar wave.
- For packages with leads on two sides and a pitch (e):
  - larger than or equal to 1.27 mm, the footprint longitudinal axis is preferred to be parallel to the transport direction of the printed-circuit board;
  - smaller than 1.27 mm, the footprint longitudinal axis must be parallel to the transport direction of the printed-circuit board.

The footprint must incorporate solder thieves at the downstream end.

• For packages with leads on four sides, the footprint must be placed at a 45° angle to the transport direction of the printed-circuit board. The footprint must incorporate solder thieves downstream and at the side corners.

During placement and before soldering, the package must be fixed with a droplet of adhesive. The adhesive can be applied by screen printing, pin transfer or syringe dispensing. The package can be soldered after the adhesive is cured.

Typical dwell time is 4 seconds at 250 °C. A mildly-activated flux will eliminate the need for removal of corrosive residues in most applications.

#### 15.4 Manual soldering

Fix the component by first soldering two diagonally-opposite end leads. Use a low voltage (24 V or less) soldering iron applied to the flat part of the lead. Contact time must be limited to 10 seconds at up to 300 °C.

When using a dedicated tool, all other leads can be soldered in one operation within 2 to 5 seconds between 270 and 320  $^\circ\text{C}.$ 

### SAA7356HL

#### 15.5 Suitability of surface mount IC packages for wave and reflow soldering methods

| PACKAGE                                      | SOLDERING METHOD                  |                       |  |
|----------------------------------------------|-----------------------------------|-----------------------|--|
| FACKAGE                                      | WAVE                              | REFLOW <sup>(1)</sup> |  |
| BGA, LFBGA, SQFP, TFBGA                      | not suitable                      | suitable              |  |
| HBCC, HLQFP, HSQFP, HSOP, HTQFP, HTSSOP, SMS | not suitable <sup>(2)</sup>       | suitable              |  |
| PLCC <sup>(3)</sup> , SO, SOJ                | suitable                          | suitable              |  |
| LQFP, QFP, TQFP                              | not recommended <sup>(3)(4)</sup> | suitable              |  |
| SSOP, TSSOP, VSO                             | not recommended <sup>(5)</sup>    | suitable              |  |

#### Notes

- 1. All surface mount (SMD) packages are moisture sensitive. Depending upon the moisture content, the maximum temperature (with respect to time) and body size of the package, there is a risk that internal or external package cracks may occur due to vaporization of the moisture in them (the so called popcorn effect). For details, refer to the Drypack information in the "Data Handbook IC26; Integrated Circuit Packages; Section: Packing Methods".
- 2. These packages are not suitable for wave soldering as a solder joint between the printed-circuit board and heatsink (at bottom version) can not be achieved, and as solder may stick to the heatsink (on top version).
- 3. If wave soldering is considered, then the package must be placed at a 45° angle to the solder wave direction. The package footprint must incorporate solder thieves downstream and at the side corners.
- 4. Wave soldering is only suitable for LQFP, TQFP and QFP packages with a pitch (e) equal to or larger than 0.8 mm; it is definitely not suitable for packages with a pitch (e) equal to or smaller than 0.65 mm.
- 5. Wave soldering is only suitable for SSOP and TSSOP packages with a pitch (e) equal to or larger than 0.65 mm; it is definitely not suitable for packages with a pitch (e) equal to or smaller than 0.5 mm.

SAA7356HL

#### 16 DATA SHEET STATUS

| DATA SHEET STATUS         | PRODUCT<br>STATUS | DEFINITIONS (1)                                                                                                                                                                                                                                                     |
|---------------------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Objective specification   | Development       | This data sheet contains the design target or goal specifications for product development. Specification may change in any manner without notice.                                                                                                                   |
| Preliminary specification | Qualification     | This data sheet contains preliminary data, and supplementary data will be<br>published at a later date. Philips Semiconductors reserves the right to<br>make changes at any time without notice in order to improve design and<br>supply the best possible product. |
| Product specification     | Production        | This data sheet contains final specifications. Philips Semiconductors reserves the right to make changes at any time without notice in order to improve design and supply the best possible product.                                                                |

#### Note

1. Please consult the most recently issued data sheet before initiating or completing a design.

#### **17 DEFINITIONS**

**Short-form specification** — The data in a short-form specification is extracted from a full data sheet with the same type number and title. For detailed information see the relevant data sheet or data handbook.

Limiting values definition — Limiting values given are in accordance with the Absolute Maximum Rating System (IEC 60134). Stress above one or more of the limiting values may cause permanent damage to the device. These are stress ratings only and operation of the device at these or at any other conditions above those given in the Characteristics sections of the specification is not implied. Exposure to limiting values for extended periods may affect device reliability.

**Application information** — Applications that are described herein for any of these products are for illustrative purposes only. Philips Semiconductors make no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

#### 18 DISCLAIMERS

Life support applications — These products are not designed for use in life support appliances, devices, or systems where malfunction of these products can reasonably be expected to result in personal injury. Philips Semiconductors customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Philips Semiconductors for any damages resulting from such application.

**Right to make changes** — Philips Semiconductors reserves the right to make changes, without notice, in the products, including circuits, standard cells, and/or software, described or contained herein in order to improve design and/or performance. Philips Semiconductors assumes no responsibility or liability for the use of any of these products, conveys no licence or title under any patent, copyright, or mask work right to these products, and makes no representations or warranties that these products are free from patent, copyright, or mask work right infringement, unless otherwise specified.

# SAA7356HL

NOTES

# Philips Semiconductors – a worldwide company

Netherlands: Postbus 90050, 5600 PB EINDHOVEN, Bldg. VB, Argentina: see South America Tel. +31 40 27 82785, Fax. +31 40 27 88399 Australia: 3 Figtree Drive, HOMEBUSH, NSW 2140, New Zealand: 2 Wagener Place, C.P.O. Box 1041, AUCKLAND, Tel. +61 2 9704 8141, Fax. +61 2 9704 8139 Tel. +64 9 849 4160, Fax. +64 9 849 7811 Austria: Computerstr. 6, A-1101 WIEN, P.O. Box 213, Tel. +43 1 60 101 1248. Fax. +43 1 60 101 1210 Norway: Box 1, Manglerud 0612, OSLO, Tel. +47 22 74 8000, Fax. +47 22 74 8341 Belarus: Hotel Minsk Business Center, Bld. 3, r. 1211, Volodarski Str. 6, 220050 MINSK, Tel. +375 172 20 0733, Fax. +375 172 20 0773 Pakistan: see Singapore Belgium: see The Netherlands Philippines: Philips Semiconductors Philippines Inc., 106 Valero St. Salcedo Village, P.O. Box 2108 MCC, MAKATI, Brazil: see South America Metro MANILA, Tel. +63 2 816 6380, Fax. +63 2 817 3474 Bulgaria: Philips Bulgaria Ltd., Energoproject, 15th floor, Poland: Al.Jerozolimskie 195 B, 02-222 WARSAW, 51 James Bourchier Blvd., 1407 SOFIA, Tel. +359 2 68 9211, Fax. +359 2 68 9102 Tel. +48 22 5710 000, Fax. +48 22 5710 001 Portugal: see Spain Canada: PHILIPS SEMICONDUCTORS/COMPONENTS, Tel. +1 800 234 7381, Fax. +1 800 943 0087 Romania: see Italy China/Hong Kong: 501 Hong Kong Industrial Technology Centre, Russia: Philips Russia, UI. Usatcheva 35A, 119048 MOSCOW, 72 Tat Chee Avenue, Kowloon Tong, HONG KONG, Tel. +7 095 755 6918, Fax. +7 095 755 6919 Tel. +852 2319 7888, Fax. +852 2319 7700 Singapore: Lorong 1, Toa Payoh, SINGAPORE 319762, Tel. +65 350 2538, Fax. +65 251 6500 Colombia: see South America Czech Republic: see Austria Slovakia: see Austria Denmark: Sydhavnsgade 23, 1780 COPENHAGEN V, Tel. +45 33 29 3333, Fax. +45 33 29 3905 Finland: Sinikalliontie 3, FIN-02630 ESPOO, Tel. +358 9 615 800, Fax. +358 9 6158 0920 France: 51 Rue Carnot, BP317, 92156 SURESNES Cedex, Tel. +33 1 4099 6161, Fax. +33 1 4099 6427 Germany: Hammerbrookstraße 69, D-20097 HAMBURG, Tel. +49 40 2353 60, Fax. +49 40 2353 6300 Hungary: see Austria India: Philips INDIA Ltd, Band Box Building, 2nd floor, 254-D, Dr. Annie Besant Road, Worli, MUMBAI 400 025, Tel. +91 22 493 8541, Fax. +91 22 493 0966 Indonesia: PT Philips Development Corporation, Semiconductors Division, Gedung Philips, Jl. Buncit Raya Kav.99-100, JAKARTA 12510, Tel. +62 21 794 0040 ext. 2501, Fax. +62 21 794 0080 Ireland: Newstead, Clonskeagh, DUBLIN 14, Tel. +353 1 7640 000, Fax. +353 1 7640 200 Israel: RAPAC Electronics, 7 Kehilat Saloniki St, PO Box 18053, TEL AVIV 61180, Tel. +972 3 645 0444, Fax. +972 3 649 1007 Italy: PHILIPS SEMICONDUCTORS, Via Casati, 23 - 20052 MONZA (MI), Tel. +39 039 203 6838. Fax +39 039 203 6800 Japan: Philips Bldg 13-37, Kohnan 2-chome, Minato-ku, TOKYO 108-8507, Tel. +81 3 3740 5130, Fax. +81 3 3740 5057 Korea: Philips House, 260-199 Itaewon-dong, Yongsan-ku, SEOUL, Tel. +82 2 709 1412, Fax. +82 2 709 1415 Malaysia: No. 76 Jalan Universiti, 46200 PETALING JAYA, SELANGOR, Tel. +60 3 750 5214, Fax. +60 3 757 4880 Mexico: 5900 Gateway East, Suite 200, EL PASO, TEXAS 79905, Tel. +9-5 800 234 7381, Fax +9-5 800 943 0087 Middle East: see Italy

For all other countries apply to: Philips Semiconductors,

Marketing Communications, Building BE-p, P.O. Box 218, 5600 MD EINDHOVEN, The Netherlands, Fax. +31 40 27 24825

© Philips Electronics N.V. 2000

All rights are reserved. Reproduction in whole or in part is prohibited without the prior written consent of the copyright owner. The information presented in this document does not form part of any quotation or contract, is believed to be accurate and reliable and may be changed without notice. No liability will be accepted by the publisher for any consequence of its use. Publication thereof does not convey nor imply any license under patent- or other industrial or intellectual property rights.

Printed in The Netherlands

753503/01/pp36

Date of release: 2000 Nov 17

Document order number: 9397 750 06181

Let's make things better.







SCA70

Slovenia: see Italy South Africa: S.A. PHILIPS Pty Ltd., 195-215 Main Road Martindale, 2092 JOHANNESBURG, P.O. Box 58088 Newville 2114, Tel. +27 11 471 5401, Fax. +27 11 471 5398

South America: Al. Vicente Pinzon, 173, 6th floor, 04547-130 SÃO PAULO, SP, Brazil Tel. +55 11 821 2333. Fax. +55 11 821 2382

Spain: Balmes 22, 08007 BARCELONA Tel. +34 93 301 6312, Fax. +34 93 301 4107

Sweden: Kottbygatan 7, Akalla, S-16485 STOCKHOLM, Tel. +46 8 5985 2000, Fax. +46 8 5985 2745

Switzerland: Allmendstrasse 140, CH-8027 ZÜRICH, Tel. +41 1 488 2741 Fax. +41 1 488 3263

Taiwan: Philips Semiconductors, 5F, No. 96, Chien Kuo N. Rd., Sec. 1, TAIPEI, Taiwan Tel. +886 2 2134 2451, Fax. +886 2 2134 2874 Thailand: PHILIPS ELECTRONICS (THAILAND) Ltd. 60/14 MOO 11, Bangna Trad Road KM. 3, Bagna, BANGKOK 10260, Tel. +66 2 361 7910, Fax. +66 2 398 3447 Turkey: Yukari Dudullu, Org. San. Blg., 2.Cad. Nr. 28 81260 Umraniye, ISTANBUL, Tel. +90 216 522 1500, Fax. +90 216 522 1813

Ukraine: PHILIPS UKRAINE, 4 Patrice Lumumba str., Building B, Floor 7, 252042 KIEV, Tel. +380 44 264 2776, Fax. +380 44 268 0461

United Kingdom: Philips Semiconductors Ltd., 276 Bath Road, Hayes, MIDDLESEX UB3 5BX, Tel. +44 208 730 5000, Fax. +44 208 754 8421 United States: 811 East Arques Avenue, SUNNYVALE, CA 94088-3409,

Tel. +1 800 234 7381, Fax. +1 800 943 0087 Uruguay: see South America

Vietnam: see Singapore

Yugoslavia: PHILIPS, Trg N. Pasica 5/v, 11000 BEOGRAD, Tel. +381 11 3341 299, Fax.+381 11 3342 553

Internet: http://www.semiconductors.philips.com